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(54) System and method for distributed object resource management 

(57) A distributed object oriented computer system 
that has two classes of object references: strong refer- 
ences and weak references. Weak references (or point- 
ers) allow users to refer to an object, but does not 
prevent the object manager from deleting the object. A 
weak object reference can be converted into a strong 
object reference by execution of a "MakeStrong" opera: 
tion, which generates a strong reference, and then 
deleting the weak reference. A strong object reference 
can be converted into a weak object reference by exe- 
cution of a "MakeWeak" operation, which returns a 
weak reference to the object referred to in the opera- 
tion's argument, and then deleting the strong reference. 
When an object no longer has any outstanding strong 
object references, deletion of the object is enabled. In 
another aspect of the invention, a portion of the compu- 
ters memory is set aside for a primary linker cache and 
a secondary linker image cache. Linker images, gener- 
ated while loading programs for execution, are stored in 
the primary and secondary linker caches. Each linker 
image in the primary linker cache has strong object ref- 
erences to objects included in corresponding ones of 
the loaded programs, and each linker image in the sec- 
ondary linker cache has weak object references to 
objects included in corresponding ones of the loaded 
programs. 
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Description 

The present invention relates generally to object 
oriented operating systems, and particularly to a system 
and method for facilitating the deletion of objects. s 

BACKGROUND OF THE INVENTION 

A distributed object based computer system must 
provide some way of informing object managers when w 
they may safely destroy their objects and reclaim their 
resources. Common solutions include reference count- 
ing, which keeps count of references to each object and 
deletes an object when its reference count decreases to 
zero, and garbage collecting, which deletes an object is 
when the system can prove that there are no remaining 
references to an object. 

However, such strategies fail for a certain class of 
references where the object's user wishes to keep a ref- 
erence to an object without preventing its deletion and 20 
resource reclamation. This class of reference occurs in 
caches of computed values, where the computed value 
may be safely recomputed, object browsers, where the 
act of viewing an object should not prevent that object 
from being deleted from the system, and other scenar* 25 
ios. 

SUMMARY OF THE INVENTION 

In summary, an embodiment of the present inven- 30 
tion is a distributed object oriented computer system in 
which the object oriented operating system provides for 
the destruction of object resources through the use of 
two classes of object references: strong references and 
weak references. Weak references (e.g., pointers) allow 35 
users to refer to an object, but does not prevent the 
object manager from deleting the object. 

In systems using a reference counting methodol- 
ogy, an object is queued for deletion when the count of 
strong references to the object reaches a predefined 40 
threshold value. In systems using a garbage collection 
methodology, any object having no outstanding strong 
object references (with the possible exception of one 
reference held by the object's object manager) will be 
garbage collected and thereby deleted at the time of the 45 
next garbage collection cycle. 

A weak object reference can be converted 'into a 
strong object reference by execution of a "MakeStrong" 
operation, which generates a strong reference, and then 
deleting the weak reference. The MakeStrong operation so 
checks to see if the object referred to still exists, and 
returns a strong reference if the object still exists. A 
strong object reference can be converted into a weak 
object reference by execution of a "MakeWeak" opera- 
tion, which returns a weak reference to the object 55 
referred to in the operation's argument, and then delet- 
ing the strong reference. When an object no longer has 
any outstanding strong object references, deletion of 
the object is enabled. 



The present invention incurs no additional distrib- 
uted communication costs to users of objects who do 
not wish to use the new "weak" class of object refer- 
ences because those users use only the normal strong 
object reference mechanisms. Furthermore, an object 
manager in a distributed system using the present 
invention does not have to keep a list of object users, 
and the object manager does not need to engage in any 
distributed communications when it destroys objects. 

More specifically, in a preferred implementation of 
the present invention, for each object stored in the 
memory, the operating system's nucleus stores refer- 
ence count data representing the number of strong 
object references to the object. The reference count 
data is decremented for an object whenever a strong 
object reference to the object is destroyed. Further- 
more, deletion of an object is initiated whenever the ref- 
erence count data of the object is decremented to a 
predefined threshold value, without regard to how many 
weak object references to the object may exist. 

In another aspect of the invention, a portion of the 
computer's memory is set aside for a primary linker 
cache and a secondary linker image cache. Linker 
images, generated while loading programs for execu- 
tion, are stored in the primary and secondary linker 
caches. Each linker image in the primary linker cache 
has strong object references to objects included in cor- 
responding ones of the loaded programs, and each 
linker image in the secondary linker cache has weak 
object references to objects included in corresponding 
ones of the loaded programs. 

When the primary linker cache is full and space for 
another linker image is needed in the primary linker 
cache, a linker image is moved from the primary linker 
cache to the secondary linker cache (to make room for 
the other linker image) and the strong object references 
in the moved linker image are converted into weak 
object references. The weak object references in the 
linker images in the secondary linker cache do not pre- 
vent delection of the referenced objects, thereby allow- 
ing the corresponding resources to be released if they 
are not referenced by any strong object references else- 
where in the system. 

When a linker image in the secondary linker cache 
is to be used to initiate execution of a corresponding 
program, the linker image is moved from the secondary 
linker cache to the primary linker cache and the weak 
object references in the moved linker image are con- 
verted into strong object references. 

BRIEF DESCRIPTION OF THE DRAWINGS 

Examples of the invention will now be described in 
conjunction with the drawings, in which: 

Fig. 1 is a block diagram of a prior art multi-compu- 
ter system using an object oriented operating sys- 
tem and an object dereferencing procedure for 
deleting objects no longer referenced by any other 
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objects. 

Fig. 2 is a block diagram of the data structures 
associated with a typical linked procedure. 

Fig. 3 is a block diagram of a multi-computer sys- 
tem using an object oriented operating system that 
supports strong and weak object references in 
accordance with an embodiment of the present 
invention. 

Fig. 4 is a flow chart of a preferred embodiment of a 
"MakeWeak" procedure for generating a; weak 
object reference corresponding to a specified 
strong object reference. 

Fig. 5 is a flow chart of a preferred embodiment of a 
"MakeStrong" procedure for generating a strong 
object reference corresponding to a specified weak 
object reference. 

Fig. 6 is a block diagram of the data structures 
associated with linked procedures in a system 
incorporating an embodiment of the present inven- 
tion. 

Fig. 7 is a flow chart of a preferred embodiment of a 
procedure for obtaining a linker image for a speci- 
fied program using the methodology of an embodi- 
ment of the present invention. 

DESCRIPTION OF THE PREFERRED EMBODI- 
MENTS 

Referring to Fig. 1, there is shown a distributed 
computer system 100 including at least one file server 
computer 102 and at least one workstation or other end 
user computer 1 04 that communicate via a communica- 
tions network 106. such as a local area network, a wide 
area network, or a combination of networks. As shown 
in Fig. 1. references to an object 1 10 stored on the file 
server 102 can be made from data structures within the 
server's main operating system domain 1 12, a local pro- 
gram 1 14 running in a separate domain 1 16 on the file 
server 102. as well as programs 118 running on other 
computer platforms in the system such as a workstation 
104. 

A domain is defined to be a process with its own 
address space. A domain can have multiple threads of 
execution (usually called threads). 

In the preferred embodiment, the operating system 
used is the Spring operating system, which is a product 
of Sun Microsystems, Inc. Background information on 
the Spring operating system can be found in "The 
Spring Nucleus: A microkernel for objects," Proceed- 
ings of the 1993 Summer Usenix Conference. June 
1993; and "An Overview of the Spring System." Pro- 
ceedings of Compcon Spring 1994, February 1994, 
both of which are hereby incorporated by reference. 
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Cross-domain references to objects and some in- 
domain references, often called object pointers or 
object references, are preferably made via two data 
structures called doors 120. and door tables 122. 

5 

Object Access via Doors 

Doors 120 are the mechanism for issuing cross- 
domain calls to objects. If a domain is granted access to 

w a door, one the domain's threads may subsequently 
issue a cross-domain call through the door to the object 
referenced by that door. When the nucleus of the oper- 
ating system executes the door call, it also records 
some return information within the nucleus. Tnis return 

15 information consists of the caller's domain, the program 
counter to which to return after the call, and the stack 
pointer of the caller at the time it issued the call. After 
the call has completed, the called domain will execute a 
door return and the nucleus will use the previously 

20 recorded return information to return control to the 
caller. 

Doors are pieces of protected nucleus state. Each 
domain has an associated door table 122 maintained by 
the nucleus for the domain. A domain references doors 

25 using door identifiers 124, which are mapped through 
the domain's door table 122 injo actual doors 120. A 
given door may be referenced by several different door 
identifiers in several different domains. Thus, the actual 
doors themselves are not in the address space of the 

30 user accessible domains, but each domain does incfude 
a door table 122 that is used to map door identifiers into 
actual doors. Furthermore, the doors referenced by the 
door table in any one domain can point to objects in 
other domains. For example, a local program 114 run- 

35 ning in domain 116 can contain a door identifier 124-1 
that is mapped by its domain-specified door table 1 22-1 
to a specific door 120-1 . which in turn enables access to 
an object 1 10 in a different domain 1 12 from the local 
program 114. 

40 When a door identifier {see 124-2) references an 
object (e.g., 110) resident on another computer (e.g., 
102) in the distributed system 100, the corresponding 
door 120-2 (as mapped by door table 122-2) actually 
points to a proxy 1 30, which communicates with another 

45 proxy 132 on the computer in which the referenced 
object resides. That proxy 132, in turn, contains a door 
table 122-3 that references a door 120-3 on the same 
computer as the object being referenced. 

Possession of a valid door identifier 124 gives the 

so possessor the right to send an invocation request to the 
given door. A valid door identifier can only be obtained 
with the consent of the target domain or with the con- 
sent of someone who already has a door identifier for 
the same door. 

55 In addition to cross domain object references imple- 
mented as door identifiers, the system 100 includes 
local object references 125 to objects in the same 
domain as the object. 
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Object Deletion 

Many servers are interested in knowing when all 
the customers for a given object have destroyed all their 
references to the object, so that they can safely destroy 
the object and free any resources that the object is 
using in the server s address space. Clients generally 
cannot issue explicit object deletion requests because 
an object cannot be deleted while it is still in use by 
other domains. 

Instead, a simple reference counting mechanism is 
used. Whenever a domain is granted access jp an 
object via the creation of an additional object reference, 
the object's reference count is incremented by the/oper- 
ating system. Whenever a domain loses access* to an 
object (either voluntarily, or due to the domain crashing, 
or due to the door being revoked), the operating system 
decrements the reference count for the object. When 
the reference count is decremented from 2 to 1, the 
nucleus notes that it should deliver an "unreferenced" 
call on the corresponding object to its server. A count of 
"1" is used as the value for unreferencing an object 
because it is normal for the object's object manager to 
retain a reference to each object that it implements. 

To support these object maintenance services, 
each participating computer will include an object refer- 
ence deletion procedure 1 34, an unreference procedure 
135 for deleting objects for which there are no longer 
any references, and the nucleus will include a reference 
counting procedure 136 that increments and decre- 
ments each object's reference count as object refer- 
ences to the object are created and deleted and which 
sends an unreferenced call to an object's server when 
the reference count for the object is decremented to a 
value of 1 . 

The nucleus keeps a queue of unreferenced doors 
for each domain, and uses a single nucleus thread per 
domain to process that queue and to call into the 
domain to deliver an unreferenced call on each of these 
unreferenced doors. Unreference calls are made by the 
domains in which the corresponding objects reside, 
thereby allowing an orderly processing of unreference 
calls when many doors may become unreferenced 
simultaneously, for example, due to a client domain exit- 
ing. 

An unreferenced call notifies an object's server that 
there are no remaining object references to the object. 
The server may then remove its reference to the object, 
delete the door, and delete the object itself. In the pre- 
ferred embodiment of the invention, the deletion of the 
door and object are normally performed immediately 
upon the execution of an unreferenced call on the door. 
In a garbage collection based system, the object's 
server would normally respond to an unreferenced call 
by deleting the door. Deletion of the corresponding 
object would occur during the next garbage collection 
cycle, at which time all objects with no remaining refer- 
ences are garbage collected. 



Cached Object References 

Referring to Fig. 2, when a program in a user 
domain 1 50 calls for the loading of a program a linker 

5 procedure 152 is invoked. The linker procedure 152 
locates all the library procedure files 154 and program 
files 156 needed to create an executable representation 
of the program to be loaded, and generates a linker 
image" 160-1 that points to ail the located files. In addi- 

io tion, the linker generates a set of fix-up pages 162-1 
which represent pages of the program files and library 
procedure files modified by the linker procedure in order 
to generate an executable program. For the purposes of 
this explanation, it can be assumed that the set of fix-up 

is pages generated in response to a load program com- 
mand are treated as a single object, and that the linker 
image 160-1 also points to the set of fix-up pages 162-1 . 

The linker images are implemented as objects, and 
a linker cache 170 is used to store object references to 

20 the linker images 160. Each of the "pointers" in the 
linker images is itself an object reference, which is 
implemented as a door identifier in the preferred 
embodiment whenever the object reference is a cross 
domain object reference, as explained above. In addi- 

25 tion, the user program domain 150 also maintains 
object references to all the program and library modules 
and the fix-up pages so long as it continues to execute 
the loaded program. These object references prevent 
deletion of any of the objects referenced by the linker 

30 image and the user program domain so long as those 
object references are not relinquished. 

The linker cache 170 has a limited capacity, typi- 
cally sufficient to hold references to about fifty or so 
linker images 160. The linker 152 maintains a hash 

35 table 171 and a list 172 of the cached linker images in 
"least recently used" order (i.e.. each time a linker 
image is used, it is moved to the head of the list). The 
hash table 171 is a conventional hash table used to 
quickly locate items in the LRU list 172. When the linker 

40 cache 1 70 is full, and another linker image needs to be 
generated in response to a load program command, the 
reference in the LRU list 172 to the least recently used 
linker image is deleted and the resulting space is used 
to store a reference to a linker image for the newly load 

45 program. Deletion of an object reference in the LRU list 
1 72 enables deletion of the corresponding linker image 
1 60 when all user program domains also relinquish their 
references to the linker image. 

The above described program linking methodology 

so can result in the production and storage of multiple sets 
of fix-up pages 162 for a single program. In particular, if 
a program is loaded once, and then kept in use for a 
long period of time, but no other load requests for the 
same program are invoked, the linker image 160 for the 

55 program will eventually be deleted because it will be the 
least recently used linker image, even though the under- 
lying program continues to execute. For instance, a user 
might load a X-windows utility program, and then leave 
his terminal on for days without reloading that program. 
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When, a day to two later, a second user loads the same 
program, the linker image for the program will have 
been deleted. The second user will be unable to access 
the linked version of the program produced in response 
to the load by the first user (because its linker image 5 
160-1 has been deleted) and the linker 152 will there- 
fore be invoked to generate a new linked version of the 
program. This results in the generation of a new linker 
image 160-2 and also a new set of fix-up pages 162-2. 
As a result, the program which is now being executed by w 
two users has two identical sets 162-1. 162-2 of fix-up 
pages. a f 

While each linker image 1 60 tends to be vejy fma". 
the set of fix-up pages 162 for each loaded /program 
tend to be voluminous. Thus it is undesirable to have is 
multiple identical sets of fix-up pages for the same pro- 
gram. However, the first set of fix-up pages cannot be 
deleted because the first user continues to execute the 
program using that first set of fix-up pages. 

While the frequency of this "multiple identical sets 20 
of fix-up pages" problem could be reduced by greatly 
increasing the size of the linker cache, that would be 
undesirable because it would prevent the deletion of the 
fix-up pages for programs no longer in use. thereby 
making a poor use of memory resources. Also, this 25 
would not represent a complete solution because some 
linker images would still be flushed from the system as 
more and more programs are loaded. In fact, from the 
viewpoint that the fix-up pages for programs no longer in 
use should be deleted as soon as possible, it would be 30 
desirable to make the linker cache 170 smaller, not 
larger. 



Inadvertent Object Retention 
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Referring again to Fig. 1. consider the situation 
where the program 118 on the client computer is an 
object browser. The user of the client computer, with the 
assistance of the browser 118. views an object 110 on 
the server 102. This creates a strong object reference, <*o 
in the form of a door identifier in the corresponding 
proxy 132. As a result, even after the browser moves on 
to look at other objects on either the same or another 
server, the object reference may continue to exist and 
thereby prevent deletion of the object. Unless, the client 45 
computer makes an explicit command to consume or 
otherwise delete the object reference for the object, the 
object reference in the proxy may be maintained until 
the calling domain in the client computer terminates. 

50 

Weak Object References 

Referring to Fig. 3. the present invention modifies 
the system described with reference to Figs. 1 and 2 to 
support both regular or strong references to objects, as ss 
well as weak object references. In the modified system 
190, strong object references are defined as references 
that prevent the deletion of the referenced object. That 
is. whenever at least one strong reference to an object 



remains in existence, the operating system kernel 198 
will not delete that object. However, weak references to 
an object will not prevent an object from being deleted. 

Weak references to an object, such as weak refer- 
ences to object 110 in Fig. 3. are implemented in the 
preferred embodiment as object references to a special 
class of objects called "companion" objects 200. The 
only function of a companion object 200 is to point to 
another object, such as object 1 10. As shown in Fig. 3. 
local program 202 contains a weak object reference 
(door identifier 204-1) and remotely located program 
206 also contains a weak object reference (door identi- 
fier 204-2) to object 1 10 in the server 102. These weak 
object references point to two doors 120-4 and 120-5 in 
the server, which in turn point to two companion objects 
200. Each of the companion objects 200 contains a 
pointer to the referenced object 1 10. 

The object deletion methodology of the system 190 
remains unchanged. Thus, object 1 10 is not deleted so 
long as any door to the object has a reference count 
greater than 1 . However, the weak object references are 
actually pointers to the companion objects 200, and 
thus existence of one or more doors pointing to the 
companion object 200 does not affect the reference, 
count for object 110. Therefore, if no other object refer- 
ences to the object 1 1 0 existed other than the two weak 
object references, none of the doors to object 1 1 0 would 
have a reference count greater than one and thus the 
object 1 10 would be available for deletion. More specifi- 
cally, when the last strong reference to object 110 is 
deleted, causing the associate door's reference count to 
decrease from 2 to 1. the operating system nucleus will 
make a call to the unreference procedure 135 of the 
object's server, putting that object on a queue of objects 
to be deleted by the server. 

Similarly, normal reference counting is used to con- 
trol the deletion of companion objects 200. That is, 
when the object holding the corresponding weak object 
reference (i.e., door identifier) to a companion object 
releases the weak object reference, the only remaining 
reference to the companion object will be the reference 
from object manager for companion objects (not shown 
in the Figs.). As a result the reference count for the com- 
panion object's door will decrease from 2 to 1 when the 
weak object reference is released, making the compan- 
ion object available for deletion. 

In the preferred embodiment, every time a new 
weak object reference is created by an entity a new 
companion object is created. This is true regardless of 
whether the new weak object reference is created by an 
entity on the same computer or a different computer 
from the referenced object. 

Each server supporting weak references includes 
two special procedures for handling the two classes of 
object references: a MakeWeak procedure 210 is used 
to generate a weak object reference corresponding to a 
specified strong object reference, and a MakeStrong 
procedure 212 is used to generate a strong object refer- 
ence corresponding to a specified weak object refer- 
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ence. 

Referring to Fig. 4, the MakeWeak function 
receives as an argument a strong object reference, 
which points directly or indirectly to an object. A corre- 
sponding weak object reference is generated by the 
MakeWeak procedure 210 by (A) creating a companion 
object for the referenced object (step 210a). and (B) cre- 
ating a weak object reference to the companion object 
(step 210b), and returning that weak object reference to 
the calling thread. While the "weak object reference" is 
commonly referred to as an object reference to the cor- 
responding non-companion object, in the preferred 
implementation the weak object reference is actually an 
object reference to a companion object. j ! 

Referring to Fig. 5, the MakeStrong function 
receives as an argument a weak object reference, 
which points to a companion object. A corresponding 
strong object reference is generated by the MakeStrong 
procedure by (A) checking to see if the non-companion 
object to be referenced still exists (step 212a). and (B) 
creating a strong object reference to the object refer- 
enced by the companion object (step 212b). In the pre- 
ferred implementation, the generation of a strong object 
reference automatically increases by 1 the reference 
count of the referenced object. If the non-companion 
object corresponding to the specified weak object refer- 
ence no longer exists (step 212a), the MakeStrong pro- 
cedure exits with an error message return (step 210c). 

Cached Strong and Weak Object References 

Referring to Fig. 6. in the preferred embodiment the 
linker cache 1 70 of Fig. 2 is replaced with a smaller pri- 
mary linker cache 220 and an expanded secondary 
linker cache 222. The primary linker cache 220 includes 
a hash table 224 and an LRU list 226 that stores strong 
object references to the least recently used linker 
images 160. while the secondary linker cache 222 
includes a hash table 228 and an LRU list 230 that 
stores strong object references to the linker images 160 
least recently used after the linker images referenced by 
the primary linker cache 220. 

For ease of explanation, linker image objects 160 
referenced by the LRU list 226 in the primary linker 
cache 222 are commonly referred to as "linker images 
in the primary linker cache", and linker image objects 
160 referenced by the LRU list 230 in the secondary 
linker cache 222 are commonly referred to as '"linker 
images in the secondary linker cache," even though the 
linker images themselves are not stored inside the linker 
caches. In addition, the object references stored in the 
LRU fists are sometimes said to "point" to various linker 
images, and the deletion M an item in an LRU list means 
that the corresponding object reference is deleted. 

All object references in the linker images 230 in the 
primary linker cache 220 are strong object references, 
while all object references in the linker images 232 in 
the secondary linker cache 222 are weak object refer- 
ences. The object references in the LRU lists to the 



linker image objects are strong object references. 

The linker cache 170 (see Fig. 2) in a typical prior 
art system is large enough to reference 50 or so linker 
images 160. while in a system 190 using the present 

5 invention the primary linker cache 200 is preferably 
large enough to reference only about 20 or so linker 
images and the secondary linker cache 222 is large 
enough to reference 200 or so linker images. 

Thus, the 20 or so most recently used linker images 

io are referenced by the LRU list 226 stored in the primary 
linker cache 220. while the next 200 or so most recently 
used linker images are referenced by the LRU list 230 
stored in the secondary linker cache 232. When a new 
linker image is generated by the modified linker proce- 

is dure 234. that causes all the items in the primary linker 
cache's LRU list 226 to be moved down one position in 
the list. If the primary linker cache 226 was full before 
the new linker image was generated, then the object ref- 
erence to least recently used of the linker images in the 

20 primary linker cache will be moved into the secondary 
tinker cache, and all the strong object references in the 
moved linker image are replaced by weak object refer- 
ences. 

When a linker image is moved into the secondary 
25 cache, the objects referenced by the linker image are 
not automatically deleted, because other entities in the 
computer system may also be referencing those same 
objects. 

For instance, if a user process is still executing the 

30 program corresponding to the moved linker image, all 
the objects referenced by the moved linker image will 
have strong object references held by that user process. 

Referring to Figs. 6 and 7, when a user program 
requests a linker image for a specified program, the 

35 modified linker procedure 234 checks to see if a linker 
image for the specified program is already in the pri- 
mary cache (step 250a). If so, a reference PTR to the 
linker image is temporarily held by the linker procedure, 
and the reference to the linker image in the primary 

40 cache's LRU list is deleted (step 250b). 

Steps 250c through 250f of the modified linker pro- 
cedure serve to create room in the primary linker 
cache's LRU list 226, if such room is needed, for a refer- 
ence to the linker image for the user specified program. 

45 In particular, if the primary linker cache is full (step 
250c), and the secondary linker cache is full (step 
250d). the last item in the secondary linker cache's LRU 
list is deleted (step 250e). Then the last item in the pri- 
mary linker cache's LRU list 226 is inserted at the top of 

so the secondary linker cache's LRU list 230 and deleted 
from the primary linker cache's LRU list 226 (step 250f). 
Furthermore, the MakeWeak procedure is called on all 
the strong object references in the linker image refer- 
enced by the item inserted at the top of the secondary 

55 linker cache s LRU list 230 to generate a corresponding 
set of weak object references, and all the strong object 
references in the referenced linker image are deleted 
(step 250f). As a result, all the strong object references 
in the linker image that was moved into the secondary 
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tinker cache 222 are replaced with corresponding weak 
object references. 

Next, an object reference to the linker image for the 
user specified program is inserted at the top of the pri- 
mary linker cache's LRU list 226 (step 250g) and then 
the linker image corresponding to that object reference 
is returned to the calling user program (step 250h). 

If a linker image for the specified program is not 
already in the primary cache (step 250a), the secondary 
linker cache is checked (step 250i). If the linker.image 
for the specified program is found in the secondary 
linker cache, a reference PTR to the linker irjfia.ge is 
stored and the reference to the linker image in^he sec- 
ondary cache's LRU list 230 is deleted (step 250j). In 
addition, the MakeStrong procedure is called on all the 
weak object references in this linker image to generate 
a corresponding set of strong object references, and all 
the weak object references in the referenced linker 
image are deleted (step 250j). As a result, all the weak 
object references in the linker image removed from the 
secondary linker cache 222 are replaced with corre- 
sponding strong object references. 

If the call to the MakeStrong procedure is success- 
ful (step 250k), the procedure continues processing at 
step 250c, as described above. If the call to the Make- 
Strong procedure fails (step 250k). that is typically 
because one or more of the objects referenced by the 
referenced linker image have been deleted, which can 
happen since the referenced linker image contained 
only weak object references. When the call to the Make- 
Strong procedure fails, a new linker image for the spec- 
ified program is created (step 250m) and an object 
reference to that linker image is temporarily held by the 
linker procedure until it is inserted at the top of the pri- 
mary linker cache's LRU list (at step 250g). Then proce- 
dure resumes processing at step 250c. 

Finally, if a linker image for the specified program is 
not found in either the primary or secondary linker 
caches, a linker image for the specified program is cre- 
ated (step 250m) and an object reference to that linker 
image is temporarily held by the linker procedure until it 
is inserted at the top of the primary linker cache's LRU 
list (at step 250g). Then linker procedure resumes 
processing at step 250c. 

ALTERNATE EMBODIMENTS 

As mentioned above, in systems using a garbage 
collection methodology instead of a reference count 
methodology, any object having no outstanding strong 
object references (with the possible exception of one 
reference held by the object's object manager) will be 
garbage collected and thereby deleted at the time of the 
next garbage collection cycle. An embodiment of the 
invention is implemented in such system by treating 
only strong object references as object references that 
prevent an object from being garbage collected. That is, 
only strong object references cause an object to be 
retained during garbage collection, while weak object 



reference do not cause an object to be retained during 
garbage collection. 

In another alternate embodiment two classes of 
object references could be supported directly, without 
the use of companion objects. In such a system, if refer- 
ence counting is used the operating system would keep 
a reference count only of strong object references and 
would initiate the deletion of objects when the reference 
count is decremented to a threshold value. In garbage 
collection systems, weak object references would be 
ignored during the garbage collection process, thereby 
causing objects with only weak object references (as 
well as objects with no object references) not to be 
retained during garbage collection. 
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Claims 



1 . In a computer system having a memory storing a 
plurality of objects, a method of determining when 
to delete ones of said objects, the steps of the 
method comprising: 

storing in said memory strong object refer- 
ences to a plurality of said objects; 
generating a weak object reference corre- 
sponding to a specified one of said objects; 
in response to predefined commands, deleting 
specified ones of said strong object references; 
enabling deletion of said one of said objects 
when less than a predefined threshold number 
of strong object references to said one of said 
objects exist in said computer system, without 
regard to how many weak object references to 
said one of said objects may exist. 

2. The method of claim 1 . 

generating weak object references correspond- 
ing to a plurality of said objects; 
generating a strong object reference corre- 
sponding to a specified one of said weak object 
references, including verifying existence of the 
object corresponding to said weak object refer- 
ence; 

preventing deletion of the object corresponding 
to said generated strong object reference. 

3. The method of claim 1 , 

setting aside in said memory a primary linker 
cache and a secondary linker image cache; 
storing linker images, generated while loading 
programs for execution, in said primary and 
secondary linker caches, each linker image in 
said primary linker cache including strong 
object references to objects included in corre- 
sponding ones of said loaded programs, each 
linker image in said secondary linker cache 
including weak object references to objects 
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included in corresponding ones of said loaded 
programs, said linker image storing step includ- 
ing: 

moving a linker image from said primary s 
linker cache to said secondary linker cache 
when said primary linker cache is full and 
space for another linker image is to stored 
in said primary linker cache; 
moving a linker image from said secondary w 
linker cache to said primary linker cache 
when said linker image is to be used/to ini- 
tiate execution of a corresponding pro- 
gram; if t 
when moving a linker image from said pri- 15 
mary linker cache to said secondary linker 
cache, replacing said strong object refer- 
ences in said moved linker image with cor- 
responding weak object references; and 
when moving a linker image from said sec- 20 
ondary linker cache to said primary linker 
cache, replacing said weak object refer- 
ences in said moved linker image with cor- 
responding strong object references. 

25 

The method of claim 3, 

replacing a specified strong object reference to 
said one of said objects with a weak object ref- 
erence by: 30 

creating a companion object that includes 
a pointer to said one of said objects; 
generating an object reference to said 
companion object; and 35 
destroying said specified strong object ref- 
erence; 

wherein said object reference to said com- 
panion object comprises a weak object reference to <o 
said one of said objects. 

The method of claim 1 , 

for a plurality of objects stored in said memory, 45 
storing reference count data representing said 
strong object references to said objects; 
decrementing said reference count data for one 
of said objects whenever a strong object refer- 
ence to said one of said objects is destroyed; so 
and 

initiating deletion of said one of said objects 
when said reference count data for said one of 
said objects is decremented to a predefined 
threshold value. 55 

The method of claim 1 , 

replacing a specified strong object reference to 



said one of said objects with a weak object ref- 
erence by: 

creating a companion object that includes 
a pointer to said one of said objects; 
generating an object reference to said 
companion object; and 
destroying said specified strong object ref- 
erence; 

wherein said object reference to said com- 
panion object comprises a weak object reference to 
said one of said objects. 

7. A computer system, comprising: 

a memory storing a plurality of objects, and 
strong object references to a plurality of said 
objects; 

a makeweak module configured to generate 
weak object references corresponding to spec- 
ified ones of said strong object references; 
a reference deleting module configured to 
delete specified ones of said strong object ref- 
erences; and 

an object management module configured to 
enable deletion of said pne of said objects 
when less than a predefined threshold number 
of strong object references to said one of said 
objects exist in said computer system, without 
regard to how many weak object references to 
said one of said objects may exist. 

8. The computer system of claim 7, 

a makestrong module configured to generate a 
strong object reference corresponding to a 
specified one of said weak object references, 
including verifying existence of the object cor- 
responding to said weak object reference; 
said object management module preventing 
deletion of the object corresponding to said 
generated strong object reference. 

9. The computer system method of claim 7, 

a program linking module, including a primary 
linker cache and a secondary linker image 
cache, configured to generate linker images 
while loading programs for execution and for 
storing said tinker images in said primary and 
secondary linker caches, each linker image in 
said primary linker cache including strong 
object references to objects included in corre- 
sponding ones of said loaded programs, each 
linker image in said secondary linker cache 
including weak object references to objects 
included in corresponding ones of said loaded 
programs, said program linking module further 
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configured to: 



move a linker image from said primary 
linker cache to said secondary linker cache 
when said primary linker cache is full and s 
space for another linker image is to stored 
in said primary linker cache; 
move a linker image from said secondary 
linker cache to said primary linker cache 
when said linker image is to be used to ini- io 
tiate execution of a corresponding pro- 
gram; | i 
when moving a linker image from said pri- 
mary linker cache to said secondary "linker 
cache, replace said strong object refer- rs 
ences in said moved linker image with cor- 
responding weak object references; and 
when moving a linker image from said sec- 
ondary linker cache to said primary linker 
cache, replace said weak object refer- 20 
ences in said moved linker image with cor- 
responding strong object references. 



1 0. The computer system of claim 9, 



11. The computer system of claim 7, including: 



25 



said makeweak module further configured to 
create a companion object that includes a 
pointer to said one of said objects and to gen- 
erate an object reference to said companion 
object; 30 

wherein said object reference to said com- 
panion object comprises a weak object reference to 
said one of said objects. 



35 



a nucleus module configured to store reference 
count data representing said strong object ref- 
erences to a plurality of said objects, to decre- to 
ment said reference count data for one of said 
objects whenever a strong object reference to 
said one of said objects is destroyed, and to ini- 
tiate deletion of said one of said objects when 
said reference count data for said one of said 45 
objects is decremented to a predefined thresh- 
old value. 



12. The computer system of claim 7, 

50 

said makeweak module further configured to 
create a companion object that includes a 
pointer to said one of said objects, and to gen- 
erate an object reference to said companion 
object; 55 

wherein said object reference to said com- 
panion object comprises a weak object reference to 
said one of said objects. 
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tion's argument and then deleting the strong reference. 
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ter's memory is set aside for a primary linker cache and 
a secondary linker image cache. Linker images* gener- 
ated while loading programs for execution, are stored in 
the primary and secondary linker caches. Each linker 
image in the primary linker cache has strong object ref- 
erences to objects included in corresponding ones of 
the loaded programs, and each linker image in the sec- 
ondary linker cache has weak object references to 
objects included in corresponding ones of the loaded 
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